/* ============================================================
   PANADERÍA LOS PUEBLOS — Estilo "Mexicano Contemporáneo"
   Terracota · barro · editorial. Serif Cormorant + Jost.
   ============================================================ */

:root{
  --bg:#f6efe3;          /* off-white cálido */
  --bg-2:#efe6d6;        /* arena */
  --card:#fbf5ea;        /* crema tarjeta */
  --terra:#c2683f;       /* terracota (acento principal) */
  --terra-deep:#a8542f;
  --barro:#7e3b23;       /* barro oscuro */
  --barro-2:#5e2c1a;
  --ink:#2c2018;
  --muted:#5a463a;
  --line:#e2d2b8;
  --line-2:#d8c4a8;
  --red:#e23a3c;         /* rojo de marca (acento) */
  --green:#1f8a55;       /* whatsapp */

  --accent:var(--terra);          /* tweakable */
  --accent-deep:var(--terra-deep);

  --maxw:1180px;
  --rad:12px;

  --f-display:'Cormorant Garamond', Georgia, serif;
  --f-body:'Jost', system-ui, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--f-body);color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;overflow-x:clip;line-height:1.6;font-weight:400;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 40px;position:relative;z-index:2}
section{position:relative;z-index:2}

/* ---------- Tipografía base ---------- */
.kicker{
  display:inline-flex;align-items:center;gap:12px;color:var(--accent);
  text-transform:uppercase;letter-spacing:.3em;font-size:12px;font-weight:500;
}
.kicker::before{content:"";width:42px;height:1px;background:currentColor}
.script{
  font-family:var(--f-display);font-style:italic;font-weight:400;
  color:var(--accent);line-height:1;
}
h1,h2,h3{margin:0;line-height:1.04;font-weight:500}

/* ============================================================
   Barra de anuncio + Nav
   ============================================================ */
.topbar{
  background:var(--barro);color:#f1e3d0;overflow:hidden;white-space:nowrap;
  position:relative;z-index:60;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
}
.topbar .track{display:inline-flex;gap:0;animation:slidebar 34s linear infinite}
.topbar span{padding:9px 26px;display:inline-flex;align-items:center;gap:14px}
.topbar b{color:#eab98a}
.star{color:var(--terra);font-size:.9em}
@keyframes slidebar{to{transform:translateX(-50%)}}

.nav{
  position:sticky;top:0;z-index:50;background:rgba(246,239,227,.86);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);transition:box-shadow .25s, background .25s;
}
.nav.scrolled{box-shadow:0 10px 30px -18px rgba(126,59,35,.4)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:16px 40px;display:flex;align-items:center;gap:28px}
.brand{display:flex;align-items:center;margin-right:auto}
.brand img{height:52px;width:auto}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{
  font-weight:500;font-size:13.5px;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);position:relative;padding:4px 0;transition:color .18s;
}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--accent);transition:right .25s}
.nav-links a:hover{color:var(--accent)}
.nav-links a:hover::after,.nav-links a.active::after{right:0}
.nav-links a.active{color:var(--ink)}

/* Botones generales */
.btn{
  display:inline-flex;align-items:center;gap:9px;font-weight:500;font-size:13px;
  letter-spacing:.08em;text-transform:uppercase;padding:12px 24px;border-radius:40px;
  border:1.5px solid transparent;transition:background .2s, color .2s, border-color .2s, transform .15s;
}
.btn.red,.btn.solid{background:var(--accent);color:#fbf5ea;border-color:var(--accent)}
.btn.red:hover,.btn.solid:hover{background:var(--accent-deep);border-color:var(--accent-deep)}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn.link{padding:0 0 3px;border-radius:0;border-bottom:1.5px solid var(--ink);color:var(--ink)}
.btn.link:hover{color:var(--accent);border-color:var(--accent)}
.btn.wa{background:transparent;color:var(--barro);border-color:var(--accent)}
.btn.wa:hover{background:var(--accent);color:#fbf5ea}
.btn.login{background:var(--barro);color:#f5ead9;border-color:var(--barro)}
.btn.login:hover{background:var(--ink);border-color:var(--ink)}
.btn svg{width:16px;height:16px}
.nav-toggle{display:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding:60px 0 46px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center}
.hero-eyebrow{margin-bottom:24px}
.hero h1{
  font-family:var(--f-display);font-size:clamp(3rem,6.6vw,5.6rem);line-height:.92;
  color:var(--ink);letter-spacing:-.01em;font-weight:500;
}
.hero h1 span{font-style:italic;color:var(--accent);-webkit-text-stroke:0 !important;text-shadow:none !important}
.hero .tagline{
  display:inline-block;font-family:var(--f-display);font-style:italic;font-weight:400;
  color:var(--barro);font-size:clamp(1.5rem,2.8vw,2rem);margin:22px 0 18px;line-height:1.2;
}
.hero p.lede{font-size:17px;max-width:46ch;color:var(--muted);margin:6px 0 34px;font-weight:300;line-height:1.7}
.hero-cta{display:flex;gap:28px;align-items:center;flex-wrap:wrap}

/* Imagen en arco */
.medallion{position:relative;display:grid;place-items:center;min-height:560px}
.arch{
  position:relative;width:min(400px,76vw);height:540px;border-radius:200px 200px 14px 14px;
  overflow:hidden;border:1px solid var(--line-2);box-shadow:0 40px 70px -34px rgba(126,59,35,.55);
}
.arch img{width:100%;height:100%;object-fit:cover}
.arch::after{content:"";position:absolute;inset:14px;border:1px solid rgba(251,245,234,.6);border-radius:188px 188px 6px 6px;pointer-events:none}
.tag-float{
  position:absolute;left:-30px;bottom:60px;background:var(--card);border:1px solid var(--line);
  padding:16px 24px;border-radius:10px;box-shadow:0 24px 50px -26px rgba(126,59,35,.6);z-index:3;
}
.tag-float .n{font-family:var(--f-display);font-size:38px;font-weight:600;color:var(--accent);line-height:1;display:flex;align-items:center;gap:6px}
.tag-float .l{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--barro);margin-top:2px}
.tag-float .dot{width:9px;height:9px;border-radius:50%;background:var(--red)}

/* ============================================================
   Marquesina — refinada
   ============================================================ */
.marquee{
  background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;white-space:nowrap;padding:18px 0;z-index:3;
}
.marquee .track{display:inline-flex;animation:slide 38s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee span{
  font-family:var(--f-display);font-style:italic;color:var(--barro);
  font-size:1.7rem;padding:0 0;display:inline-flex;align-items:center;gap:34px;
}
.marquee span span{display:inline-flex;align-items:center}
.marquee span span::after{content:"·";color:var(--terra);margin-left:34px;font-style:normal}
@keyframes slide{to{transform:translateX(-50%)}}

/* Divisor festoneado → línea fina */
.scallop{display:none}

/* ============================================================
   NOSOTROS
   ============================================================ */
.about{padding:96px 0}
.about-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:64px;align-items:center}
.about-media{position:relative}
.frame{
  position:relative;overflow:hidden;border-radius:160px 160px 12px 12px;
  border:1px solid var(--line-2);box-shadow:0 36px 64px -34px rgba(126,59,35,.5);transform:none;
}
.frame img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/4}
.frame .tape{display:none}
.frame.inset{
  position:absolute;right:-30px;bottom:-40px;width:46%;border-radius:12px;z-index:4;
  border:6px solid var(--card);box-shadow:0 26px 50px -26px rgba(126,59,35,.6);
}
.frame.inset img{aspect-ratio:1}
.about h2{font-family:var(--f-display);font-size:clamp(2.4rem,4.4vw,3.4rem);color:var(--ink);margin:14px 0 6px;line-height:1}
.about .lead{font-size:18px;color:var(--muted);font-weight:300;margin:20px 0;line-height:1.75;max-width:48ch}
.quote{
  border:0;border-left:2px solid var(--accent);background:transparent;
  padding:6px 0 6px 26px;margin:26px 0;font-family:var(--f-display);font-style:italic;
  font-size:1.5rem;line-height:1.45;color:var(--barro);box-shadow:none;
}
.values{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.value{
  display:flex;align-items:center;gap:11px;font-weight:400;font-size:14px;color:var(--ink);
  background:transparent;border:1px solid var(--line-2);border-radius:40px;
  padding:9px 20px 9px 12px;box-shadow:none;letter-spacing:.02em;
}
.value i{
  width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fbf5ea;
  display:grid;place-content:center;font-style:normal;font-size:.9rem;
}

/* ============================================================
   CATÁLOGO
   ============================================================ */
.catalog{padding:96px 0;background:var(--bg-2)}
.section-head{text-align:center;margin-bottom:18px}
.section-head .script{display:block;font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:2px}
.section-head h2{font-family:var(--f-display);font-size:clamp(2.6rem,5vw,3.8rem);color:var(--ink);line-height:1}
.section-head p{color:var(--muted);max-width:54ch;margin:14px auto 0;font-size:16px;font-weight:300}

.filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:34px 0 42px}
.chip{
  font-weight:500;letter-spacing:.06em;text-transform:uppercase;font-size:12px;
  background:transparent;border:1px solid var(--line-2);border-radius:40px;
  padding:9px 20px;color:var(--muted);box-shadow:none;transition:background .2s, color .2s, border-color .2s;
}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.active{background:var(--accent);color:#fbf5ea;border-color:var(--accent)}

.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--rad);
  overflow:hidden;box-shadow:0 18px 40px -30px rgba(126,59,35,.5);
  transition:transform .25s, box-shadow .25s;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 56px -28px rgba(126,59,35,.55)}
.card .ph{aspect-ratio:1;overflow:hidden;position:relative;border-bottom:1px solid var(--line)}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.card:hover .ph img{transform:scale(1.06)}
.card .cat{
  position:absolute;top:12px;left:12px;background:rgba(251,245,234,.92);color:var(--barro);
  font-weight:500;font-size:10px;text-transform:uppercase;letter-spacing:.14em;
  padding:5px 12px;border-radius:30px;border:1px solid var(--line);
}
.card .label{padding:18px 16px 20px;text-align:center;background:var(--card)}
.card .label h3{font-family:var(--f-display);font-weight:600;font-size:1.4rem;color:var(--ink);line-height:1.1}
.card .label .pueblo{font-family:var(--f-body);font-weight:300;color:var(--accent);font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-top:6px;display:block}
.card.hide{display:none}
.card.reveal{animation:pop .35s ease both}
@keyframes pop{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.empty-note{text-align:center;color:var(--muted);grid-column:1/-1;font-style:italic;padding:30px;font-family:var(--f-display);font-size:1.3rem}

/* ============================================================
   SUCURSALES + MAPA
   ============================================================ */
.sucursales{padding:96px 0;background:var(--barro);color:#f3e6d4;position:relative}
.sucursales .section-head h2{color:#fbf5ea}
.sucursales .section-head .script{color:var(--terra);filter:brightness(1.25)}
.sucursales .section-head p{color:rgba(243,230,212,.82)}
.suc-grid{display:grid;grid-template-columns:1fr 1.15fr;gap:34px;margin-top:42px;align-items:start}
.suc-list{display:flex;flex-direction:column;gap:12px}
.suc{
  text-align:left;background:rgba(251,245,234,.06);color:#f3e6d4;
  border:1px solid rgba(243,230,212,.18);border-radius:var(--rad);padding:18px 20px;
  box-shadow:none;transition:background .2s, border-color .2s, transform .15s;
  display:flex;gap:16px;align-items:flex-start;width:100%;
}
.suc:hover{background:rgba(251,245,234,.1);border-color:rgba(243,230,212,.35);transform:translateX(3px)}
.suc.active{background:var(--card);border-color:var(--card);color:var(--ink)}
.suc.active p{color:var(--muted)}
.suc.active .go{color:var(--accent)}
.suc .pin{
  flex:none;width:36px;height:36px;border-radius:50%;background:var(--terra);color:#fbf5ea;
  display:grid;place-content:center;font-weight:500;font-family:var(--f-display);font-size:1.2rem;border:0;
}
.suc.active .pin{background:var(--terra)}
.suc h3{font-family:var(--f-display);font-weight:600;font-size:1.3rem}
.suc p{margin:3px 0 0;font-size:13.5px;color:rgba(243,230,212,.72);line-height:1.5;font-weight:300}
.suc .go{font-weight:500;font-size:11px;color:#eab98a;text-transform:uppercase;letter-spacing:.12em;margin-top:8px;display:inline-block}
.suc-map{
  position:sticky;top:96px;border:1px solid rgba(243,230,212,.2);border-radius:var(--rad);
  overflow:hidden;box-shadow:0 30px 60px -30px rgba(0,0,0,.5);background:var(--bg-2);
}
.suc-map iframe{display:block;width:100%;height:520px;border:0;filter:saturate(1.02) sepia(.04)}

/* Horarios */
.hours-strip{margin-top:52px;display:flex;gap:28px;align-items:center;justify-content:center;flex-wrap:wrap}
.open-sign{
  background:transparent;color:#fbf5ea;border:1px solid rgba(243,230,212,.3);border-radius:10px;
  padding:16px 30px;text-align:center;box-shadow:none;
}
.open-sign .o{font-family:var(--f-display);font-style:italic;font-size:1.8rem;letter-spacing:.02em;color:#7fdca7;display:block}
.open-sign .sub{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(243,230,212,.75);font-weight:500}
.hours-text{color:#f3e6d4;font-weight:300}
.hours-text strong{color:#fbf5ea;font-size:1.5rem;font-weight:500;display:block;font-family:var(--f-display)}
.hours-note{font-size:11.5px;opacity:.6;font-style:italic;display:block;margin-top:6px}

/* ============================================================
   CONTACTO
   ============================================================ */
.contact{padding:96px 0;background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center;margin-top:8px}
.contact-aside h2{font-family:var(--f-display);font-size:clamp(2.2rem,4vw,3rem);color:var(--ink);line-height:1.05}
.contact-aside p{color:var(--muted);font-size:16px;margin:18px 0 26px;max-width:40ch;font-weight:300;line-height:1.7}
.contact-aside .social{display:flex;gap:12px}
.soc{
  width:50px;height:50px;border-radius:50%;display:grid;place-content:center;
  background:transparent;color:var(--barro);border:1px solid var(--line-2);box-shadow:none;
  transition:background .2s, color .2s, border-color .2s;
}
.soc:hover{background:var(--accent);color:#fbf5ea;border-color:var(--accent)}
.soc svg{width:22px;height:22px;fill:currentColor}

.form{background:var(--card);border:1px solid var(--line);border-radius:var(--rad);padding:34px;box-shadow:0 30px 60px -36px rgba(126,59,35,.5)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--barro);margin-bottom:8px}
.field input,.field textarea{
  width:100%;font-family:var(--f-body);font-size:15px;color:var(--ink);font-weight:300;
  background:var(--bg);border:1px solid var(--line-2);border-radius:8px;padding:13px 15px;transition:border-color .15s, box-shadow .15s;
}
.field input::placeholder,.field textarea::placeholder{color:#a8917e}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(194,104,63,.12)}
.field textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form .btn{width:100%;justify-content:center;font-size:13px;padding:15px}
.form-ok{
  display:none;text-align:center;padding:28px;background:transparent;
  border:1px dashed var(--accent);border-radius:12px;color:var(--barro);font-weight:400;
}
.form-ok.show{display:block;animation:pop .4s ease both}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--barro-2);color:#e9d9c6;padding:72px 0 30px;position:relative}
.footer::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--terra),var(--barro))}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:48px;margin-bottom:40px}
.footer .brand img{height:60px}
.footer .ftag{font-family:var(--f-display);font-style:italic;color:#eab98a;font-size:1.7rem;margin:18px 0 8px;line-height:1.2}
.footer p{color:rgba(233,217,198,.72);font-size:14px;max-width:34ch;font-weight:300;line-height:1.7}
.footer h4{font-family:var(--f-display);color:#fbf5ea;font-size:1.3rem;font-weight:600;margin:0 0 16px}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.footer ul a{color:rgba(233,217,198,.8);font-weight:300;font-size:14px;letter-spacing:.02em;transition:color .15s}
.footer ul a:hover{color:#eab98a}
.foot-bottom{border-top:1px solid rgba(233,217,198,.16);padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:rgba(233,217,198,.55);font-weight:300}

/* ============================================================
   WhatsApp flotante
   ============================================================ */
.wa-fab{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.wa-bubble{
  background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;max-width:240px;
  box-shadow:0 24px 50px -26px rgba(126,59,35,.6);transform-origin:bottom right;transition:opacity .2s, transform .2s;
}
.wa-bubble.hide{opacity:0;transform:scale(.85) translateY(10px);pointer-events:none}
.wa-bubble .t{font-family:var(--f-display);font-weight:600;font-size:1.2rem;margin-bottom:4px;color:var(--barro)}
.wa-bubble .m{font-size:13px;color:var(--muted);margin-bottom:12px;font-weight:300}
.wa-bubble a{display:inline-flex;gap:8px;align-items:center;background:var(--green);color:#fff;font-weight:500;padding:9px 16px;border-radius:30px;font-size:12.5px;letter-spacing:.04em}
.wa-btn{
  width:60px;height:60px;border-radius:50%;background:var(--green);border:0;
  display:grid;place-content:center;box-shadow:0 16px 30px -12px rgba(31,138,85,.7);transition:transform .15s;
}
.wa-btn:hover{transform:scale(1.06)}
.wa-btn svg{width:32px;height:32px;fill:#fff}
.wa-btn .dot{position:absolute;top:-2px;right:-2px;width:18px;height:18px;border-radius:50%;background:var(--red);border:2px solid #fff;color:#fff;font-size:.62rem;font-weight:600;display:grid;place-content:center}

/* ============================================================
   Reveal on scroll
   ============================================================ */
.reveal-up{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.reveal-up.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal-up{opacity:1;transform:none;transition:none}
  .marquee .track,.topbar .track{animation:none}
}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:980px){
  .hero-grid,.about-grid,.suc-grid,.contact-grid{grid-template-columns:1fr}
  .medallion{min-height:360px;order:1}
  .grid{grid-template-columns:repeat(2,1fr)}
  .frame.inset{position:relative;right:auto;bottom:auto;width:58%;margin:-30px auto 0}
  .suc-map{position:relative;top:0}
  .suc-map iframe{height:380px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg);
    flex-direction:column;padding:18px;border-bottom:1px solid var(--line);gap:14px}
  .nav-links.open{display:flex}
  .nav-links a{width:100%}
  .nav-toggle{display:grid;place-content:center;width:44px;height:44px;border:1px solid var(--line-2);
    border-radius:10px;background:transparent;color:var(--barro);font-size:1.2rem}
  .nav .btn.wa{display:none}
  .grid{grid-template-columns:1fr 1fr;gap:16px}
  .form-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .wrap{padding:0 22px}
  .arch{height:340px}
  /* Mobile-first hero: texto primero, imagen después */
  .hero-grid{gap:24px;padding-top:16px}
  .hero-copy{order:0}
  .medallion{order:1;min-height:300px}
}
@media(max-width:440px){
  .grid{grid-template-columns:1fr}
}
